std::literals::chrono_literals:: operator""s
|
Definido en el encabezado
<chrono>
|
||
|
constexpr
std::
chrono
::
seconds
operator "" s ( unsigned long long secs ) ; |
(1) | (desde C++14) |
|
constexpr
std::
chrono
::
duration
<
/*unspecified*/
>
operator "" s ( long double secs ) ; |
(2) | (desde C++14) |
Forma un literal std::chrono::duration que representa segundos.
Contenidos |
Parámetros
| secs | - | el número de segundos |
Valor de retorno
El literal std::chrono::duration .
Implementación posible
constexpr std::chrono::seconds operator""s(unsigned long long s) { return std::chrono::seconds(s); } constexpr std::chrono::duration<long double> operator""s(long double s) { return std::chrono::duration<long double>(s); } |
Notas
Este operador se declara en el espacio de nombres std :: literals :: chrono_literals , donde tanto literals como chrono_literals son espacios de nombres en línea . Se puede acceder a este operador mediante:
- using namespace std :: literals ,
- using namespace std :: chrono_literals , o
- using namespace std :: literals :: chrono_literals .
Además, dentro del espacio de nombres std :: chrono , la directiva using namespace literals :: chrono_literals ; es proporcionada por la biblioteca estándar , de modo que si un programador utiliza using namespace std :: chrono ; para obtener acceso a las clases en la biblioteca chrono , los operadores literales correspondientes también se vuelven visibles.
std::string
también define
operator
""
s
, para representar objetos literales de tipo
std::string
, pero es un literal de cadena:
10s
son diez segundos, pero
"10"
s
es una cadena de dos caracteres.
Ejemplo
#include <chrono> #include <iostream> int main() { using namespace std::chrono_literals; std::chrono::seconds halfmin = 30s; std::cout << "Half a minute is " << halfmin.count() << " seconds" " (" << halfmin << ").\n" "A minute and a second is " << (1min + 1s).count() << " seconds.\n"; std::chrono::duration moment = 0.1s; std::cout << "A moment is " << moment.count() << " seconds" " (" << moment << ").\n" "And thrice as much is " << (moment + 0.2s).count() << " seconds.\n"; }
Salida:
Half a minute is 30 seconds (30s). A minute and a second is 61 seconds. A moment is 0.1 seconds (0.1s). And thrice as much is 0.3 seconds.
Véase también
|
construye una nueva duración
(función miembro pública de
std::chrono::duration<Rep,Period>
)
|